#pragma once
#include "gtest/gtest.h"
#include "DataStructure/Input/Property/BeamSectionStandardTypes.h"
#include "../Interface/BarSectionFormulaCalculatorFactory.h"
#include "../Bar/Tube2SectionFormulaCalculator.h"

using SG::Algebra::Point;
using namespace SG::DataStructure::FEM;
using SG::FEMSolver::Element::BarSectionFormulaCalculatorFactory;
using SG::FEMSolver::Element::Tube2SectionFormulaCalculator;

// 将 BarSectionFormulaCalculatorFactory 生成对象测试放置在具体截面属性计算中
TEST (BarSectionFormulaCalculatorFactoryTest, Tube2SectionCalculatorCreate)
{
    // Test data
    auto calculatorPtr = BarSectionFormulaCalculatorFactory::Create (BeamSectionStandardTypes::BEAMSECTYPE_TUBE2);
    auto tube2CalculatorPtr = dynamic_cast<Tube2SectionFormulaCalculator*> (calculatorPtr.get ());

    // Check
    ASSERT_TRUE (nullptr != tube2CalculatorPtr);
}

// Tube2 截面属性计算测试
TEST (BarSectionFormulaCalculatorTest, Tube2Section)
{
    // Input data
    PBARLData section;
    section.m_id  = 2;
    section.m_mId = 3;
    section.SetGroup ("MSCBML0");
    section.SetBeamSectionStandardTypes (BeamSectionStandardTypes::BEAMSECTYPE_TUBE2);
    section.m_dimension = {4.0, 2.0};
    section.m_nsm = 10.0;

    // Test data
    Tube2SectionFormulaCalculator calculator;
    PBARData propertyTest;
    Point centroidTest;
    calculator.Compute (section, _OUT propertyTest, _OUT centroidTest);

    // Target data
    PBARData propertyTarget;
    propertyTarget.m_id  = 2;
    propertyTarget.m_mId = 3;
    propertyTarget.m_A   = 37.69911;
    // propertyTarget.m_yS = 0.0;
    // propertyTarget.m_zS = 0.0;
    // propertyTarget.m_yC = 0.0;
    // propertyTarget.m_zC = 0.0;
    propertyTarget.m_I1  = 188.4956;
    propertyTarget.m_I2  = 188.4956;
    propertyTarget.m_I12 = 0.0;
    propertyTarget.m_J   = 376.9911;
    propertyTarget.m_K1  = 0.5;
    propertyTarget.m_K2  = 0.5;
    propertyTarget.m_NSM = 10.0;
    propertyTarget.m_FE  = 0.0;
    propertyTarget.SetStressPoints ({4.0, 0.0, 0.0, 4.0, -4.0, 0.0, 0.0, -4.0});
    Point centroidTarget;

    // Check
    ASSERT_TRUE (propertyTarget == propertyTest);
    ASSERT_TRUE (centroidTarget == centroidTest);
}